ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> nil
ap2(ap2(ap2(if, false), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(map, f), ap2(dropLast, xs)))
ap2(isEmpty, nil) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> false
ap2(last, ap2(ap2(cons, x), nil)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, nil) -> nil
ap2(dropLast, ap2(ap2(cons, x), nil)) -> nil
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
↳ QTRS
↳ DependencyPairsProof
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> nil
ap2(ap2(ap2(if, false), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(map, f), ap2(dropLast, xs)))
ap2(isEmpty, nil) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> false
ap2(last, ap2(ap2(cons, x), nil)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, nil) -> nil
ap2(dropLast, ap2(ap2(cons, x), nil)) -> nil
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
AP2(ap2(map, f), xs) -> AP2(ap2(if, ap2(isEmpty, xs)), f)
AP2(ap2(ap2(if, false), f), xs) -> AP2(last, xs)
AP2(ap2(ap2(if, false), f), xs) -> AP2(f, ap2(last, xs))
AP2(ap2(map, f), xs) -> AP2(if, ap2(isEmpty, xs))
AP2(ap2(ap2(if, false), f), xs) -> AP2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(map, f), ap2(dropLast, xs)))
AP2(ap2(map, f), xs) -> AP2(isEmpty, xs)
AP2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(last, ap2(ap2(cons, y), ys))
AP2(ap2(ap2(if, false), f), xs) -> AP2(ap2(map, f), ap2(dropLast, xs))
AP2(ap2(map, f), xs) -> AP2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
AP2(ap2(ap2(if, false), f), xs) -> AP2(map, f)
AP2(ap2(ap2(if, false), f), xs) -> AP2(cons, ap2(f, ap2(last, xs)))
AP2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(dropLast, ap2(ap2(cons, y), ys))
AP2(ap2(ap2(if, false), f), xs) -> AP2(dropLast, xs)
AP2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> nil
ap2(ap2(ap2(if, false), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(map, f), ap2(dropLast, xs)))
ap2(isEmpty, nil) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> false
ap2(last, ap2(ap2(cons, x), nil)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, nil) -> nil
ap2(dropLast, ap2(ap2(cons, x), nil)) -> nil
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
AP2(ap2(map, f), xs) -> AP2(ap2(if, ap2(isEmpty, xs)), f)
AP2(ap2(ap2(if, false), f), xs) -> AP2(last, xs)
AP2(ap2(ap2(if, false), f), xs) -> AP2(f, ap2(last, xs))
AP2(ap2(map, f), xs) -> AP2(if, ap2(isEmpty, xs))
AP2(ap2(ap2(if, false), f), xs) -> AP2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(map, f), ap2(dropLast, xs)))
AP2(ap2(map, f), xs) -> AP2(isEmpty, xs)
AP2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(last, ap2(ap2(cons, y), ys))
AP2(ap2(ap2(if, false), f), xs) -> AP2(ap2(map, f), ap2(dropLast, xs))
AP2(ap2(map, f), xs) -> AP2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
AP2(ap2(ap2(if, false), f), xs) -> AP2(map, f)
AP2(ap2(ap2(if, false), f), xs) -> AP2(cons, ap2(f, ap2(last, xs)))
AP2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(dropLast, ap2(ap2(cons, y), ys))
AP2(ap2(ap2(if, false), f), xs) -> AP2(dropLast, xs)
AP2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> nil
ap2(ap2(ap2(if, false), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(map, f), ap2(dropLast, xs)))
ap2(isEmpty, nil) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> false
ap2(last, ap2(ap2(cons, x), nil)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, nil) -> nil
ap2(dropLast, ap2(ap2(cons, x), nil)) -> nil
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
AP2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(dropLast, ap2(ap2(cons, y), ys))
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> nil
ap2(ap2(ap2(if, false), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(map, f), ap2(dropLast, xs)))
ap2(isEmpty, nil) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> false
ap2(last, ap2(ap2(cons, x), nil)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, nil) -> nil
ap2(dropLast, ap2(ap2(cons, x), nil)) -> nil
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
AP2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(dropLast, ap2(ap2(cons, y), ys))
POL(AP2(x1, x2)) = 2·x1·x2 + 3·x2
POL(ap2(x1, x2)) = 3·x1 + 3·x1·x2
POL(cons) = 3
POL(dropLast) = 1
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> nil
ap2(ap2(ap2(if, false), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(map, f), ap2(dropLast, xs)))
ap2(isEmpty, nil) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> false
ap2(last, ap2(ap2(cons, x), nil)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, nil) -> nil
ap2(dropLast, ap2(ap2(cons, x), nil)) -> nil
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
AP2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(last, ap2(ap2(cons, y), ys))
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> nil
ap2(ap2(ap2(if, false), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(map, f), ap2(dropLast, xs)))
ap2(isEmpty, nil) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> false
ap2(last, ap2(ap2(cons, x), nil)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, nil) -> nil
ap2(dropLast, ap2(ap2(cons, x), nil)) -> nil
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
AP2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(last, ap2(ap2(cons, y), ys))
POL(AP2(x1, x2)) = 2·x1·x2 + 3·x2
POL(ap2(x1, x2)) = 3·x1 + 3·x1·x2
POL(cons) = 3
POL(last) = 1
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> nil
ap2(ap2(ap2(if, false), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(map, f), ap2(dropLast, xs)))
ap2(isEmpty, nil) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> false
ap2(last, ap2(ap2(cons, x), nil)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, nil) -> nil
ap2(dropLast, ap2(ap2(cons, x), nil)) -> nil
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
AP2(ap2(ap2(if, false), f), xs) -> AP2(f, ap2(last, xs))
AP2(ap2(ap2(if, false), f), xs) -> AP2(ap2(map, f), ap2(dropLast, xs))
AP2(ap2(map, f), xs) -> AP2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> nil
ap2(ap2(ap2(if, false), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(map, f), ap2(dropLast, xs)))
ap2(isEmpty, nil) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> false
ap2(last, ap2(ap2(cons, x), nil)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, nil) -> nil
ap2(dropLast, ap2(ap2(cons, x), nil)) -> nil
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
AP2(ap2(ap2(if, false), f), xs) -> AP2(f, ap2(last, xs))
Used ordering: Polynomial interpretation [21]:
AP2(ap2(ap2(if, false), f), xs) -> AP2(ap2(map, f), ap2(dropLast, xs))
AP2(ap2(map, f), xs) -> AP2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
POL(AP2(x1, x2)) = x1
POL(ap2(x1, x2)) = 2 + x2
POL(cons) = 0
POL(dropLast) = 0
POL(false) = 0
POL(if) = 0
POL(isEmpty) = 0
POL(last) = 0
POL(map) = 3
POL(nil) = 0
POL(true) = 0
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
AP2(ap2(ap2(if, false), f), xs) -> AP2(ap2(map, f), ap2(dropLast, xs))
AP2(ap2(map, f), xs) -> AP2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> nil
ap2(ap2(ap2(if, false), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(map, f), ap2(dropLast, xs)))
ap2(isEmpty, nil) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> false
ap2(last, ap2(ap2(cons, x), nil)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, nil) -> nil
ap2(dropLast, ap2(ap2(cons, x), nil)) -> nil
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))